package com.itany.corejava.code17_设计模式.模板模式;

/**
 * @author 石小俊
 * @date 2023年06月02日 11:29
 */
public class SortTemplate {
    public static <T> void sort(T[] arr, SortComparator sc) {
        // 先制定一个顶层逻辑架构
        for (int i = 0; i < arr.length - 1; i++) {
            for (int j = 0; j < arr.length - 1 - i; j++) {
                // 将具体的实现细节留给具体的方法调用者进行实现
                // 此处对于排序而言,唯一的区别是什么时候交换?
                int result = sc.compareTo(arr[j], arr[j + 1]);
                if (result > 0) {
                    T temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
    }
}
